<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
<meta charset="UTF-8">
<title>角色管理</title>
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta http-equiv="Access-Control-Allow-Origin" content="*">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="format-detection" content="telephone=no">
<link rel="icon" href="/favicon.ico">
<link rel="stylesheet" th:href="@{/static/layui/css/layui.css}" media="all" />
<link rel="stylesheet" th:href="@{/static/css/public.css}" media="all" />
<link rel="stylesheet" th:href="@{/static/layui_ext/dtree/dtree.css}" media="all" />
<link rel="stylesheet" th:href="@{/static/layui_ext/dtree/font/dtreefont.css}" media="all" />
</head>
<body class="childrenBody">
<!-- 查询条件开始 -->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 5px;">
  <legend>查询条件</legend>
</fieldset>
<blockquote class="layui-elem-quote">
	<form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
		<div class="layui-form-item">
		    <div class="layui-inline">
		      <label class="layui-form-label">角色名称</label>
		      <div class="layui-input-inline">
		        <input type="text" name="name"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		    <div class="layui-inline">
		      <label class="layui-form-label">角色备注</label>
		      <div class="layui-input-inline">
		        <input type="text" name="remark"    autocomplete="off" class="layui-input">
		      </div>
		    </div>
		    <div class="layui-inline">
		      <label class="layui-form-label">是否可用</label>
		      <div class="layui-input-inline">
				<input type="radio" name="available" value="1"  title="可用" >
				<input type="radio" name="available" value="0" title="不可用" >
			  </div>
		    </div>
		  </div>
		  <div class="layui-form-item">
		      <div class="layui-input-block" style="text-align: center;">
		      	<button type="button" class="layui-btn" lay-submit="" lay-filter="doSearch"><span class="layui-icon layui-icon-search"></span>查询</button>
      			<button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
		      </div>
		  </div>
	</form>
</blockquote>
<!-- 查询条件结束-->


<!-- 数据表格开始 -->
<div>
	<table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
	<div id="roleToolBar" style="display: none;">
		<button type="button" lay-event="add" shiro:hasPermission="role:create"  class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-add-1"></span>添加角色</button>
	</div>
	
	<div id="roleRowBar" style="display: none;">
		<button type="button" lay-event="update" shiro:hasPermission="role:update"  class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-edit"></span>更新</button>
		<button type="button" lay-event="delete" shiro:hasPermission="role:delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
		<button type="button" lay-event="selectPermission" shiro:hasPermission="role:selectPermission"  class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-about"></span>分配权限</button>
	</div>
</div>


<!-- 数据表格结束 -->


<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding: 5px" id="addOrUpdateDiv">
	<form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
		<div class="layui-form-item">
		    <label class="layui-form-label">角色名称</label>
		    <div class="layui-input-block">
		      <input type="hidden" name="id">
		      <input type="text" name="name" lay-verify="required" autocomplete="off" placeholder="请输入标题" class="layui-input">
		    </div>
 	   </div>
		<div class="layui-form-item">
		    <label class="layui-form-label">角色备注</label>
		    <div class="layui-input-block">
		    	 <textarea class="layui-textarea" name="remark" id="remark"></textarea>
		    </div>
 	   </div>
 	    <div class="layui-form-item">
		      <label class="layui-form-label">是否可用</label>
		      <div class="layui-input-block">
		      	  <input type="radio" name="available" checked="" value="1" title="可用" >
	        	  <input type="radio" name="available" value="0" title="不可用" >
		      </div>
		    </div>
 	   <div class="layui-form-item">
		    <div class="layui-input-block" style="text-align: center;">
		      	<button type="button" class="layui-btn" lay-submit="" lay-filter="doSubmit" id="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
      			<button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
		     </div>
 	   </div>
	</form>
</div>
<!-- 添加和修改的弹出层结束 -->


<!-- 分配权限的弹出层 开始 -->
<div style="display: none;" id="selectRolePermissionDiv">
	<ul id="permissionTree" class="dtree" data-id="0"></ul>
</div>
<!-- 分配权限的弹出层 结束-->
<script type="text/javascript" th:src="@{/static/layui/layui.js}"></script>
<script type="text/javascript">
layui.extend({
    dtree: '/static/layui_ext/dtree/dtree'  
  }).use(['jquery','form','table','layer','dtree'],function(){
    var $=layui.jquery;
    var form=layui.form;
    var table=layui.table;
    var layer=layui.layer;
    var dtree=layui.dtree;
    //加载 数据
    var tableIns=table.render({
        elem: '#roleTable'
        ,url:'/role/loadAllRole'
        ,toolbar: '#roleToolBar' //开启头部工具栏，并为其绑定左侧模板
        ,title: '角色数据表'
        ,height:'full-220'
        ,page: true
        ,cols: [ [
            {field:'id', title:'ID',align:'center'}
            ,{field:'name', title:'角色名称',align:'center'}
            ,{field:'remark', title:'角色备注',align:'center'}
            ,{field:'available', title:'是否可用',align:'center',templet:function(d){
                    return d.available==1?'<font color=blue>可用</font>':'<font color=red>不可用</font>';
                }}
            ,{field:'createtime', title:'创建时间',align:'center'}
            ,{fixed: 'right', title:'操作', toolbar: '#roleRowBar',align:'center',width:'300'}
        ] ]
    });

    //模糊查询
    form.on("submit(doSearch)",function(data){
        tableIns.reload({
            where:data.field,
            page:{
                curr:1
            }
        });
        return false;
    });

    //监听工具条的事件
    table.on("toolbar(roleTable)",function(obj){
        switch(obj.event){
            case 'add':
                openAddLayer();
                break;
        };
    });

    //监听行工具条的事件
    table.on("tool(roleTable)",function(obj){
        var data = obj.data; //获得当前行数据
        switch(obj.event){
            case 'update':
                openUpdateRoleLayer(data);
                break;
            case 'delete':
                deleteRole(data);
                break;
            case 'selectPermission':
                selectPermission(data);
                break;
        };
    });

    var mainIndex;
    var url;
    //打开添加的弹出层
    function openAddLayer(){
        mainIndex=layer.open({
            type:1,
            content:$("#addOrUpdateDiv"),
            area:['800px','600px'],
            title:'添加角色',
            success:function(){
                $("#dataFrm")[0].reset();
                url="/role/addRole";
            }
        });
    }

    //打开修改的弹出层
    function openUpdateRoleLayer(data){
        mainIndex=layer.open({
            type:1,
            content:$("#addOrUpdateDiv"),
            area:['800px','600px'],
            title:'修改角色',
            success:function(){
                $("#dataFrm")[0].reset();
                //装载新的数据
                form.val("dataFrm",data);
                url="/role/updateRole";
            }
        });
    }

    form.on("submit(doSubmit)",function(data){
        $.post(url,data.field,function(res){
            if(res.code==200){
                tableIns.reload();
            }
            layer.msg(res.msg);
            layer.close(mainIndex);
        })
        return false;
    });
    //删除
    function deleteRole(data){
        layer.confirm('你确定要删除【'+data.name+'】这条角色吗?', {icon: 3, title:'提示'}, function(index){
            $.post("/role/deleteRole",{id:data.id},function(res){
                if(res.code==200){
                    tableIns.reload();
                }
                layer.msg(res.msg);
            })
            layer.close(index);
        });
    }

    //打开分配角色的页面
    function selectPermission(data){
        mainIndex=layer.open({
            type:1,
            content:$("#selectRolePermissionDiv"),
            area:['400px','600px'],
            title:'分配【'+data.name+'】的权限',
            btn: ['<span class=layui-icon>&#xe605;确认分配</span>', '<span class=layui-icon>&#x1006;关闭窗口</span>'],
            yes: function(index, layero){
                //得到树选中的所有节点
                var permissionData = dtree.getCheckbarNodesParam("permissionTree");
                console.log(params);
                var params="rid="+data.id;
                $.each(permissionData,function(index,item){
                    params+="&ids="+item.nodeId;
                });
                $.post("/role/saveRolePermission",params,function(res){
                    layer.msg(res.msg);
                })
            },
            btn2: function(index, layero){
                //return false 开启该代码可禁止点击该按钮关闭
            },
            btnAlign: 'c',
            success:function(){
                //根据角色ID请求权限和菜单tree的json数据
                dtree.render({
                    elem: "#permissionTree",
                    url: "/role/initPermissionByRoleId?roleId="+data.id,
                    dataStyle: "layuiStyle",  //使用layui风格的数据格式
                    dataFormat: "list",  //配置data的风格为list
                    response:{message:"msg",statusCode:0},  //修改response中返回数据的定义
                    checkbar: true,
                    checkbarType: "all" // 默认就是all，其他的值为： no-all  p-casc   self  only
                });
            }
        });
    }
});
</script>
</body>
</html>